আমাজন আরডিএস (Amazon RDS)

AWS CloudFormation দিয়ে RDS ডেপ্লয়মেন্ট

Database Tutorials - আমাজন আরডিএস (Amazon RDS) - AWS CLI এবং SDK দিয়ে অটোমেশন | NCTB BOOK

AWS CloudFormation দিয়ে RDS ডেপ্লয়মেন্ট একটি শক্তিশালী পদ্ধতি, যা আপনাকে Amazon RDS ইনস্ট্যান্সের স্থাপন এবং কনফিগারেশন স্বয়ংক্রিয়ভাবে পরিচালনা করতে সাহায্য করে। CloudFormation এর মাধ্যমে আপনি আপনার RDS ইনস্ট্যান্সের জন্য প্রয়োজনীয় সম্পদগুলো (যেমন VPC, Subnets, Security Groups, RDS ইন্সট্যান্স) কনফিগারেশনসহ সম্পূর্ণ স্ট্যাক হিসেবে তৈরি এবং ডেপ্লয় করতে পারেন।

AWS CloudFormation দিয়ে RDS ডেপ্লয়মেন্টের ধাপ:

AWS CloudFormation দিয়ে RDS ডেপ্লয় করতে, আপনাকে একটি CloudFormation টেমপ্লেট তৈরি করতে হবে। এটি একটি YAML বা JSON ফাইল, যা RDS ইনস্ট্যান্সসহ অন্যান্য AWS রিসোর্স কনফিগারেশনের নির্দেশনা ধারণ করে।


ধাপ ১: CloudFormation টেমপ্লেট তৈরি করা

এখানে একটি সাধারণ CloudFormation YAML টেমপ্লেট দেওয়া হলো, যা একটি RDS MySQL ইনস্ট্যান্স তৈরি করবে।

AWSTemplateFormatVersion: '2010-09-09'
Resources:
  MyRDSTemplate:
    Type: AWS::RDS::DBInstance
    Properties:
      DBInstanceIdentifier: my-database
      AllocatedStorage: 20
      DBInstanceClass: db.t3.micro
      Engine: MySQL
      EngineVersion: '8.0.23'
      MasterUsername: admin
      MasterUserPassword: !Ref DBPassword
      VPCSecurityGroups:
        - !Ref MySecurityGroup
      DBName: mydb
      MultiAZ: false
      StorageType: gp2
      BackupRetentionPeriod: 7
      PubliclyAccessible: true
      Tags:
        - Key: Name
          Value: MyDatabaseInstance
  MySecurityGroup:
    Type: AWS::EC2::SecurityGroup
    Properties:
      GroupDescription: Enable MySQL access
      SecurityGroupIngress:
        - IpProtocol: tcp
          FromPort: '3306'
          ToPort: '3306'
          CidrIp: '0.0.0.0/0'
  DBPassword:
    Type: AWS::SecretsManager::Secret
    Properties:
      Name: MyDBPassword
      SecretString: '{"username":"admin","password":"mypassword"}'

টেমপ্লেট বিশ্লেষণ:

  1. RDS Instance:
    • AWS::RDS::DBInstance: এই রিসোর্সটি MySQL ডাটাবেস ইনস্ট্যান্স তৈরি করবে।
    • DBInstanceClass: RDS ইন্সট্যান্সের পারফরম্যান্স ক্লাস নির্বাচন করা হয়েছে (এখানে db.t3.micro)।
    • Engine: ডাটাবেস ইঞ্জিন (এখানে MySQL) নির্বাচন করা হয়েছে।
    • MasterUsername এবং MasterUserPassword: ডাটাবেস অ্যাডমিন ইউজারনেম এবং পাসওয়ার্ড।
    • VPCSecurityGroups: নিরাপত্তা গ্রুপ সংযুক্ত করা হয়েছে।
    • PubliclyAccessible: এটি পাবলিক অ্যাক্সেসযোগ্য কনফিগার করেছে।
  2. Security Group:
    • AWS::EC2::SecurityGroup: MySQL পোর্ট (3306) খুলে দেওয়া হয়েছে, যাতে ডাটাবেসে পাবলিক অ্যাক্সেস পাওয়া যায়।
  3. Secrets Manager:
    • AWS::SecretsManager::Secret: ডাটাবেস পাসওয়ার্ড সুরক্ষিতভাবে Secrets Manager থেকে পরিচালনা করা হচ্ছে।

ধাপ ২: CloudFormation Stack তৈরি করা

  1. AWS Management Console এ লগইন করুন এবং CloudFormation সার্ভিস নির্বাচন করুন।
  2. Create Stack বাটনে ক্লিক করুন।
  3. Upload a Template File অপশন নির্বাচন করে আপনার YAML অথবা JSON টেমপ্লেট ফাইল আপলোড করুন।
  4. স্ট্যাকের জন্য একটি নাম দিন (যেমন MyRDSStack) এবং প্রয়োজনীয় কনফিগারেশন নিশ্চিত করুন (যেমন প্যারামিটারস, ট্যাগস ইত্যাদি)।
  5. Next বাটনে ক্লিক করে কনফিগারেশন সম্পূর্ণ করুন এবং Create Stack বাটনে ক্লিক করুন।

CloudFormation স্ট্যাকটি আপনার ডাটাবেস ইনস্ট্যান্স এবং অন্যান্য রিসোর্স তৈরি করতে শুরু করবে।


ধাপ ৩: CloudFormation স্ট্যাক মনিটরিং

  • CloudFormation Console থেকে আপনি স্ট্যাকের অবস্থা দেখতে পারবেন। স্ট্যাক তৈরি হওয়ার পর CREATE_COMPLETE স্ট্যাটাস দেখাবে।
  • আপনি যদি কোনো পরিবর্তন করতে চান, তবে স্ট্যাকটি আপডেট করতে পারবেন এবং CloudFormation স্বয়ংক্রিয়ভাবে রিসোর্সগুলো আপডেট করবে।

ধাপ ৪: ডাটাবেস কানেক্টিভিটি

CloudFormation স্ট্যাক সফলভাবে ডিপ্লয় হলে, আপনি আপনার ডাটাবেসের Endpoint এবং Port দেখতে পারবেন এবং Security Group এর মাধ্যমে ডাটাবেসে অ্যাক্সেস করতে পারবেন।

  • RDS Endpoint: CloudFormation স্ট্যাকের মাধ্যমে প্রাপ্ত Endpoint ব্যবহার করে আপনি MySQL Workbench, DBeaver, অথবা আপনার প্রোগ্রামিং ভাষা দিয়ে ডাটাবেসে কানেক্ট করতে পারবেন।

ধাপ ৫: CloudFormation স্ট্যাকের অবস্থা পরীক্ষা করা

CloudFormation স্ট্যাকটি সঠিকভাবে কাজ করছে কিনা তা পরীক্ষা করতে:

  1. CloudFormation Console থেকে স্ট্যাকের অবস্থা চেক করুন।
  2. CloudWatch Logs থেকে আপনি রিসোর্স ক্রিয়েশন সংক্রান্ত লোগস দেখতে পারেন।

সারাংশ:

  • CloudFormation দিয়ে RDS ডেপ্লয়মেন্টে আপনি YAML বা JSON ফাইল ব্যবহার করে ডাটাবেস ইন্সট্যান্স, সিকিউরিটি গ্রুপ, এবং অন্যান্য রিসোর্স স্বয়ংক্রিয়ভাবে কনফিগার এবং ডিপ্লয় করতে পারেন।
  • এটি রিসোর্স ম্যানেজমেন্ট এবং ইনফ্রাস্ট্রাকচার অটোমেশনকে সহজ করে দেয়।
  • CloudFormation দিয়ে পরিচালনা করা হলে, আপনি একাধিক পরিবেশে একই কনফিগারেশন পুনরায় ব্যবহার করতে পারেন, যা স্কেলিং এবং মেনটেনেন্স সহজ করে।

AWS CloudFormation আপনার ইনফ্রাস্ট্রাকচারকে কোড হিসেবে পরিচালনা করার জন্য একটি শক্তিশালী টুল, যা RDS ডেপ্লয়মেন্টসহ অন্য সকল রিসোর্স ম্যানেজমেন্ট স্বয়ংক্রিয়ভাবে করতে সক্ষম।

Content added By
Promotion